import { useUserStore } from '@/stores'
import NProgress from 'nprogress'
import 'nprogress/nprogress.css'
import { createRouter, createWebHistory } from 'vue-router'

const router = createRouter({
  history: createWebHistory(import.meta.env.BASE_URL),
  routes: [
    {
      path:'/',
      component:()=> import ('@/views/Layout/index.vue'),
      redirect:'/home',
      children:[
        {
          path:'/home',
          component:()=>import('@/views/Home/index.vue'),
          meta: { title: '首页' },
        },
        { 
          path: '/user',
          component: () => import('@/views/User/index.vue'),
          meta: { title: '个人中心' } 
        },
        {
          path:'/article',
          component: () => import('@/views/Article/index.vue'),
          meta: { title: '健康百科' }
        },
        {
          path:'/notify',
          component: () => import('@/views/Notify/index.vue'), 
          meta: { title: '消息通知' }     
        }
      ]
    },
    {
      path:'/login',
      component:()=>import ('@/views/Login/index.vue'),
      meta: { title: '登录' }
    },
    {
      path:'/register',
      component:()=>import('@/views/Register/index.vue'),
      meta: { title: '注册' }
    },
    {
      path:'/user/patient',
      component:()=> import ('@/views/User/PatientPage.vue'),
      meta:{title:'家庭档案'}
    },
    {
      path:'/user/address',
      component:()=> import ('@/views/User/AddressUser.vue'),
      meta:{title:'家庭档案'}
    },
    {
      path: '/consult/fast',
      component: () => import('@/views/Consult/ConsultFast.vue'),
      meta: { title: '极速问诊' }
    },
    {
      path: '/consult/dep',
      component: () => import('@/views/Consult/ConsultDep.vue'),
      meta: { title: '选择科室' }
    },
    {
      path: '/consult/illness',
      component: () => import('@/views/Consult/ConsultIllness.vue'),
      meta: { title: '病历描述' }
    },
    {
      path: '/consult/pay',
      component: () => import('@/views/Consult/ConsultPay.vue'),
      meta: { title: '问诊支付' }
    },
    {
      path: '/room',
      component: () => import('@/views/Room/index.vue'),
      meta: { title: '问诊室' }
    },
    {
      path: '/user/consult',
      component: () => import('@/views/User/ConsultPage.vue'),
      meta: { title: '问诊记录' }
    },
    {
      path: '/user/consult/:id',
      component: () => import('@/views/User/ConsultDetail.vue'),
      meta: { title: '问诊详情' }
    },
    {
      path: '/order/pay',
      component: () => import('@/views/Order/OrderPay.vue'),
      meta: { title: '药品支付' }
    },
    {
      path: '/order/pay/result',
      component: () => import('@/views/Order/OrderPayResult.vue'),
      meta: { title: '药品支付结果' }
    },
    {
      path: '/order/:id',
      component: () => import('@/views/Order/OrderDetail.vue'),
      meta: { title: '药品订单详情' }
    },
    {
      path:"/order/logistics/:id",
      component: () => import('@/views/Order/OrderLogistics.vue'),
      meta:{title:'物流详情'}
    },
    {
      path:"/login/callback",
      component: () => import('@/views/Login/LoginCallback.vue'),
      meta:{title:'第三方登录'}
    }
  ]
})
// 访问权限控制
// 路由导航前置守卫
router.beforeEach((to) => {
  NProgress.start()
  // 用户仓库
  const store = useUserStore()
  // 不需要登录的页面，白名单
  const wihteList = ['/login' , '/register','/login/callback']
  // 如果没有登录且不在白名单内，去登录
  if (!store.userInfo?.token && !wihteList.includes(to.path)) return '/login'
  // 否则不做任何处理
})
// 路由导航后置守卫
router.afterEach((to) => {
  //修改标题
  document.title = `${to.meta.title || ''}-优医问诊`
  NProgress.done()
  NProgress.configure({
    showSpinner: false
  })
})

export default router
